import router from './router'
import store from './store'
// import { Message } from 'element-ui'
import NProgress from 'nprogress' // progress bar 进度条
import 'nprogress/nprogress.css' // progress bar style 进度条样式
// import { getToken } from '@/utils/auth' // get token from cookie
// import getPageTitle from '@/utils/get-page-title' // 获取页面标题
import { asyncRoutes } from '@/router/index'

NProgress.configure({ showSpinner: false }) // NProgress Configuration 进度条加载时的旋转动画等

// 白名单
const whiteList = ['/login', '/404']

// 路由导航前置守卫
router.beforeEach(async(to, from, next) => {
  // 开启进度条
  NProgress.start()
  const token = store.getters.token
  if (token) {
    // 如果有token，继续判断是否是登录页
    if (to.path === '/login') {
      // 手动关闭进度条
      NProgress.done()
      // next(地址) 并没有执行后置守卫
      next('/')
    } else {
      // 有token且不是登录页，判断是否获取过用户信息
      // 如果有，发送请求获取，如果没有，则跳过
      if (!store.getters.userId) {
        // 1. 获取用户对应的权限 menus 页面访问权限 / points 按钮操作权限
        const { roles } = await store.dispatch('user/getUserInfo')
        // console.log(roles)
        // 2. 筛选出动态路由 - 根据当前角色的权限
        const filterRoutes = asyncRoutes.filter(item => {
          // 判断路由的name信息是否存在于权限列表中
          // 如果存在 - 保留 - 后续添加到路由表
          return roles.menus.includes(item.name)
        })
        store.commit('user/setRoutes', filterRoutes)
        // 3. 添加到路由表中 - 正常访问
        // 问题1: 由于path*是一个兜底方案，一定要放在路由表的最后
        router.addRoutes([...filterRoutes, { path: '*', redirect: '/404', hidden: true }])
        // 4. bugvue-router 3.xx版本的已知缺陷
        // 问题2: 动态添加路由信息之后，刷新会白屏，必须得转发一下，next(to.path)，才能正常访问
        next(to.path) // 目的是让路由拥有信息，会经过路由后置守卫
      } else {
        next()
      }
    }
  } else {
    if (whiteList.includes(to.path)) {
      next()
    } else {
      // 手动关闭进度条
      NProgress.done()
      next('/login')
    }
  }
})

// 注意: 拦截到某个页面时，如 登录/首页 ，进度条不会消失
// 原因：手动拦截，不会执行路由后置守卫
// 解决：在路由导航后置守卫中，手动调用进度条结束方法

// 路由导航后置守卫
router.afterEach((to, from) => {
  // console.log('路由后置守卫', to)
  // 判断是否有标题，如果有则设置标题，否则使用默认标题
  if (to.meta?.title) {
    document.title = ' 上海鸿蒙6期 - ' + to.meta.title
  }
  // 关闭进度条
  NProgress.done()
})
